gdouble *win_y,
GdkModifierType *mask)
{
- GdkWindow *toplevel;
- GdkWindowImplBroadway *impl;
GdkDisplay *display;
GdkBroadwayDisplay *broadway_display;
- GdkScreen *screen;
gint32 device_root_x, device_root_y;
guint32 mouse_toplevel_id;
- GdkWindow *mouse_toplevel;
guint32 mask32;
if (gdk_device_get_source (device) != GDK_SOURCE_MOUSE)
display = gdk_device_get_display (device);
broadway_display = GDK_BROADWAY_DISPLAY (display);
- impl = GDK_WINDOW_IMPL_BROADWAY (window->impl);
- toplevel = impl->wrapper;
-
_gdk_broadway_server_query_mouse (broadway_display->server,
&mouse_toplevel_id,
&device_root_x,
&device_root_y,
&mask32);
- mouse_toplevel = g_hash_table_lookup (broadway_display->id_ht, GUINT_TO_POINTER (mouse_toplevel_id));
if (root_x)
*root_x = device_root_x;
*mask = mask32;
if (child_window)
{
+ GdkWindowImplBroadway *impl;
+ GdkWindow *toplevel;
+ GdkWindow *mouse_toplevel;
+
+ if (window == NULL)
+ window = gdk_get_default_root_window ();
+
+ impl = GDK_WINDOW_IMPL_BROADWAY (window->impl);
+ toplevel = impl->wrapper;
+
+ mouse_toplevel = g_hash_table_lookup (broadway_display->id_ht, GUINT_TO_POINTER (mouse_toplevel_id));
if (gdk_window_get_window_type (toplevel) == GDK_WINDOW_ROOT)
{
*child_window = mouse_toplevel;
static void
gdk_mir_keyboard_query_state (GdkDevice *device,
GdkWindow *window,
- GdkWindow **root_window,
GdkWindow **child_window,
gdouble *root_x,
gdouble *root_y,
static void
gdk_mir_pointer_query_state (GdkDevice *device,
GdkWindow *window,
- GdkWindow **root_window,
GdkWindow **child_window,
gdouble *root_x,
gdouble *root_y,
{
GdkMirPointer *p = GDK_MIR_POINTER (device);
- if (root_window)
- *root_window = gdk_screen_get_root_window (gdk_display_get_default_screen (gdk_device_get_display (device)));
if (child_window)
*child_window = p->over_window;
if (root_x)
static void
gdk_quartz_device_core_query_state (GdkDevice *device,
GdkWindow *window,
- GdkWindow **root_window,
GdkWindow **child_window,
gdouble *root_x,
gdouble *root_y,
NSPoint point;
gint x_tmp, y_tmp;
+ if (window == NULL)
+ window = _gdk_root;
+
found_window = gdk_quartz_device_core_query_state_helper (window, device,
win_x, win_y,
mask);
{
GdkWaylandPointerData *pointer;
+ if (window == NULL)
+ window = gdk_get_default_root_window ();
+
pointer = GDK_WAYLAND_DEVICE (device)->pointer;
if (child_window)
static void
gdk_device_win32_query_state (GdkDevice *device,
GdkWindow *window,
- GdkWindow **root_window,
GdkWindow **child_window,
gdouble *root_x,
gdouble *root_y,
gdouble *win_y,
GdkModifierType *mask)
{
- GdkScreen *screen;
POINT point;
HWND hwnd, hwndc;
GdkWindowImplWin32 *impl;
- screen = gdk_window_get_screen (window);
+ if (window == NULL)
+ window = gdk_get_default_root_window ();
impl = GDK_WINDOW_IMPL_WIN32 (window->impl);
hwnd = GDK_WINDOW_HWND (window);
if (win_y)
*win_y = point.y / impl->window_scale;
- if (window == gdk_screen_get_root_window (screen))
+ if (window == gdk_get_default_root_window ())
{
if (win_x)
*win_x += _gdk_offset_x;
*child_window = NULL; /* Direct child unknown to gdk */
}
- if (root_window)
- *root_window = gdk_screen_get_root_window (screen);
-
if (mask)
*mask = get_current_mask ();
}
static void
gdk_device_wintab_query_state (GdkDevice *device,
GdkWindow *window,
- GdkWindow **root_window,
GdkWindow **child_window,
gdouble *root_x,
gdouble *root_y,
GdkModifierType *mask)
{
GdkDeviceWintab *device_wintab;
- GdkScreen *screen;
POINT point;
HWND hwnd, hwndc;
GdkWindowImplWin32 *impl;
device_wintab = GDK_DEVICE_WINTAB (device);
- screen = gdk_window_get_screen (window);
+ if (window == NULL)
+ window = gdk_get_default_root_window ();
impl = GDK_WINDOW_IMPL_WIN32 (window->impl);
hwnd = GDK_WINDOW_HWND (window);
*child_window = NULL; /* Direct child unknown to gdk */
}
- if (root_window)
- *root_window = gdk_screen_get_root_window (screen);
-
if (mask)
{
*mask = get_current_mask ();
gdouble *win_y,
GdkModifierType *mask)
{
- GdkWindowImplX11 *impl = GDK_WINDOW_IMPL_X11 (window->impl);
+ GdkWindowImplX11 *impl;
GdkDisplay *display;
GdkScreen *default_screen;
Window xroot_window, xchild_window;
int xroot_x, xroot_y, xwin_x, xwin_y;
unsigned int xmask;
- display = gdk_window_get_display (window);
+ display = gdk_device_get_display (device);
default_screen = gdk_display_get_default_screen (display);
+ if (window == NULL)
+ window = gdk_screen_get_root_window (default_screen);
+ impl = GDK_WINDOW_IMPL_X11 (window->impl);
if (!GDK_X11_DISPLAY (display)->trusted_client ||
!XQueryPointer (GDK_WINDOW_XDISPLAY (window),
gdouble *win_y,
GdkModifierType *mask)
{
- GdkWindowImplX11 *impl = GDK_WINDOW_IMPL_X11 (window->impl);
+ GdkWindowImplX11 *impl;
GdkX11DeviceXI2 *device_xi2 = GDK_X11_DEVICE_XI2 (device);
GdkDisplay *display;
GdkScreen *default_screen;
XIModifierState mod_state;
XIGroupState group_state;
- display = gdk_window_get_display (window);
+ display = gdk_device_get_display (device);
default_screen = gdk_display_get_default_screen (display);
+ if (window == NULL)
+ window = gdk_screen_get_root_window (default_screen);
+ impl = GDK_WINDOW_IMPL_X11 (window->impl);
if (gdk_device_get_device_type (device) == GDK_DEVICE_TYPE_SLAVE)
{